<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
	<title>菜单和权限管理</title>
	<meta name="renderer" content="webkit">
	<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
	<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
	<link rel="stylesheet" href="../../../lib/layui-v2.5.5/css/layui.css" media="all">
	<link rel="stylesheet" href="../../../lib/font-awesome-4.7.0/css/font-awesome.min.css" media="all">
	<link rel="stylesheet" href="../../../css/public.css" media="all">
</head>

<body>
<div class="layuimini-container">
	<div class="layuimini-main">
		<!--搜索开始-->
		<fieldset class="layui-elem-field layuimini-search">
			<legend>搜索信息</legend>
			<div style="margin: 10px 10px 10px 10px">
				<form class="layui-form layui-form-pane" action="" id="searchFrm">
					<div class="layui-form-item">
						<div class="layui-inline">
							<label class="layui-form-label">关键字</label>
							<div class="layui-input-inline">
								<input type="text" name="title" id="search_title" autocomplete="off" class="layui-input">
							</div>
						</div>
						<div class="layui-inline">
							<a class="layui-btn"  id="data-search-btn"><label class="layui-icon layui-icon-search"></label>搜索</a>
							<a class="layui-btn layui-btn-warm" onclick="javascript:$('#searchFrm')[0].reset()" lay-filter="data-search-btn"><label class="layui-icon layui-icon-refresh"></label>重置</a>
						</div>
					</div>
				</form>
			</div>
		</fieldset>
		<!--搜索结束-->
		<!--表格开始-->
		<a class="layui-btn" href="javascript:void(0)" id="addMenuBtn"> <span class="layui-icon layui-icon-add-1"></span> 添加</a>
		<table class="layui-hide" id="menuTable" lay-filter="menuTable"></table>
		<script type="text/html" id="menuTableBar">
			<a class="layui-btn layui-btn-xs layui-btn-warm data-count-delete" lay-event="update">修改</a>
			<a class="layui-btn layui-btn-xs layui-btn-danger data-count-delete" lay-event="delete">删除</a>
		</script>


		<script type="text/html" id="availableTpl">
			<!-- 这里的 checked 的状态只是演示 -->
			<input type="checkbox" name="available" value="{{d.id}}" lay-skin="switch" lay-text="可用|不可用" lay-filter="availableSwitch" {{ d.available == 1 ? 'checked' : '' }}>
		</script>

		<!--表格结束-->

		<!--添加和修改的弹出层开始-->
		<div id="addOrUpdateDiv" style="display: none;padding: 0.3125rem">
			<form method="post" class="layui-form layui-form-pane" lay-filter="dataFrm" id="dataFrm">
				<div class="layui-form-item" id="div_pid">
					<label class="layui-form-label">菜单类型</label>
					<div class="layui-input-block">
						<input type="radio" name="type" lay-filter="typeFilter" value="topmenu" title="顶部菜单" >
						<input type="radio" name="type" lay-filter="typeFilter" value="leftmenu" title="左侧菜单" checked="">
						<input type="radio" name="type" lay-filter="typeFilter" value="permission" title="按钮权限" >
					</div>
				</div>
				<div class="layui-form-item item_leftmenu item_permission">
					<label class="layui-form-label">父级菜单</label>
					<div class="layui-input-inline">
						<input type="hidden" name="pid" id="p_id" />
						<input type="text" name="pid_name" id="p_name" readonly="readonly" autocomplete="off" placeholder="请选择父级菜单和权限" class="layui-input">
					</div>
					<div class="layui-input-inline">
						<a class="layui-btn layui-btn-warm" id="doSelectMenu"><label class="layui-icon layui-icon-male"></label>选择</a>
					</div>
				</div>
				<div class="layui-form-item ">
					<label class="layui-form-label">名称</label>
					<div class="layui-input-block">
						<input type="hidden" name="id" />
						<input type="text" name="title" lay-verify="required" autocomplete="off" placeholder="请输入菜单和权限名称" class="layui-input">
					</div>
				</div>
				<div class="layui-form-item">
					<label class="layui-form-label">编码</label>
					<div class="layui-input-block">
						<input type="text" name="typeCode"  autocomplete="off" placeholder="请输入菜单和权限地址" class="layui-input">
					</div>
				</div>
				<div class="layui-form-item item_topmenu  item_leftmenu">
					<label class="layui-form-label">图标</label>
					<div class="layui-input-block">
						<input type="text" name="icon"  autocomplete="off" placeholder="请输入菜单和权限地址" class="layui-input">
					</div>
				</div>
				<div class="layui-form-item  item_leftmenu">
					<label class="layui-form-label">链接地址</label>
					<div class="layui-input-block">
						<input type="text" name="href"  autocomplete="off" placeholder="请输入菜单和权限地址" class="layui-input">
					</div>
				</div>
				<div class="layui-form-item item_leftmenu">
					<label class="layui-form-label">TARGET</label>
					<div class="layui-input-block">
						<input type="radio" name="target" value="_self" title="_self" checked="" >
						<input type="radio" name="target" value="_blank" title="_blank" >
					</div>
				</div>
				<div class="layui-form-item">
					<label class="layui-form-label">排序码</label>
					<div class="layui-input-block">
						<input type="text" name="sortCode" id="sortCode" lay-verify="required"  autocomplete="off" placeholder="请输入排序码" class="layui-input">
					</div>
				</div>
				<div class="layui-form-item">
					<div class="layui-input-block" style="text-align: center;">
						<a class="layui-btn " lay-submit=""  lay-filter="doSubmit"><label class="layui-icon layui-icon-release"></label>提交</a>
						<a class="layui-btn layui-btn-warm" onclick="javascript:$('#dataFrm')[0].reset()" lay-filter="data-search-btn"><label class="layui-icon layui-icon-refresh"></label>重置</a>
					</div>
				</div>
			</form>
		</div>
		<!--添加和修改的弹出层结束-->
	</div>
</div>
<script src="../../../lib/jquery-3.4.1/jquery-3.4.1.min.js" charset="utf-8"></script>
<script src="../../../lib/layui-v2.5.5/layui.js" charset="utf-8"></script>
<script src="../../../js/lay-config.js?v=1.0.4" charset="utf-8"></script>
<script src="../../../lib/jq-module/jquery.particleground.min.js" charset="utf-8"></script>
<script src="../../../lib/common/jquery.cookie.min.js" charset="utf-8"></script>
<script src="../../../lib/common/common.js" charset="utf-8"></script>
<script src="../../../lib/common/selectLayer.js" charset="utf-8"></script>


<script>
	layui.use(['form', 'table','layer','treeTable','laydate'], function () {
		var form = layui.form;
		var table = layui.table;
		var layer=layui.layer;
		var laydate=layui.laydate;
		var treeTable = layui.treeTable;

		var tableIns=treeTable.render({
			tree: {
				iconIndex: 1,  // 折叠图标显示在第几列
				idName: 'id',  // 自定义id字段的名称
				pidName: 'pid',  // 自定义标识是否还有子节点的字段名称
				isPidData: true  ,// 是否是pid形式数据
				openName: 'spread'  // 自定义默认展开的字段名
			},
			elem: '#menuTable',
			cellMinWidth:true,
			cols: [
				{type: "numbers"},
				{field: 'title',  title: '菜单或权限名称',width: 200},
				{field: 'id', title: 'ID', align: "center",width: 80},
				{field: 'pid', title: 'PID', align: "center",width: 80},
				{field: 'type',  title: '类型', align: "center",width: 120,templet: function (d) {
						if (d.type == 'topmenu') {
							return '<span class="layui-badge layui-bg-red">顶部菜单</span>';
						}
						if (d.type == 'leftmenu') {
							return '<span class="layui-badge layui-bg-blue">左侧菜单</span>';
						} else {
							return '<span class="layui-badge layui-bg-molv">权限</span>';
						}
					}
				},
				{field: 'href',  title: '地址', align: "center",width: 300},
				{field: 'typeCode',  title: '编码', align: "center",width: 120},
				{field: 'icon',  title: '图标', align: "center",width: 120,templet:function(d){
						var x="<i class='"+d.icon+"' ></i>";
						return x;
					}},
				{field: 'target',  title: 'TARGET', align: "center",width: 100},
				{field: 'sortCode',  title: '排序码', align: "center",width: 80},
				{field: 'available',  title: '是否可用', align: "center",width: 120,templet:'#availableTpl'},
				{title: '操作', templet: '#menuTableBar', fixed: "right", align: "center"}
			],
			reqData: function(data, callback) {
				if(data==undefined){
					// 在这里写ajax请求，通过callback方法回调数据
					$.get(api+'menu/loadAllMenuAndPermission', function (res) {
						callback(res.data);  // 参数是数组类型
						console.log(res.data);
					});
				}else{
					callback([]);  //回调一个空数据去渲染表格
				}

			}
		});

		// 监听搜索操作
		$("#data-search-btn").on("click",function(){
			var title=$("#search_title").val();
			if(title){
				tableIns.filterData(title);
			}else{
				tableIns.reload();
			}
		});
		//监听表单元素的事件
		//监听展开操作
		form.on('switch(spreadSwitch)', function(obj){
			$.post(api+"menu/updateMenu",{id:this.value,spread:obj.elem.checked?1:0},function(res){
				layer.msg(res.msg);
				tableIns.reload();
			})
			//layer.tips(this.value + ' ' + this.name + '：'+ obj.elem.checked, obj.othis);
		});
		//监听可用操作
		form.on('switch(availableSwitch)', function(obj){
			$.post(api+"menu/updateMenu",{id:this.value,available:obj.elem.checked?1:0},function(res){
				layer.msg(res.msg);
				tableIns.reload();
			})
		});



		//监听添加按钮的事件
		$("#addMenuBtn").click(function(){
			openAddmenu(); //打开添加的弹出层

		})

		form.on('radio(typeFilter)', function(data){
			console.log(data.value); //被点击的radio的value值
			$(".item_topmenu").show();
			$(".item_leftmenu").show();
			$(".item_permission").show();
			if(data.value=='topmenu'){
				$(".item_leftmenu").hide();
				$(".item_permission").hide();
				$(".item_topmenu").show();
			}else if(data.value=='leftmenu'){
				$(".item_permission").hide();
				$(".item_topmenu").hide();
				$(".item_leftmenu").show();
			}else{
				$(".item_leftmenu").hide();
				$(".item_topmenu").hide();
				$(".item_permission").show();
			}
		});

		//监听行数据的事件
		treeTable.on('tool(menuTable)', function (obj) {
			var data = obj.data;
			if (obj.event === 'delete') {
				$.get(api+"menu/getMenuChildrenCountById",{id:data.id},function(res1){
					if(res1.data>0){
						layer.msg("当前菜单和权限有子菜单和权限，请选择删除子菜单和权限");
					}else{
						layer.confirm('真的删除【'+data.title+'】这个菜单和权限吗?', function (index) {
							$.post(api+"menu/deleteMenu",{id:data.id},function(res){
								layer.msg(res.msg);
								obj.del();
								layer.close(index);
							})
						});
					}
				})
			}else if(obj.event === 'update'){
				openUpdatemenu(data);
			}

		});

		//打开添加公告的弹层
		var mainIndex;
		var url;  //动态的url
		function openAddmenu(){
			mainIndex=layer.open({
				type:1,
				title:'添加菜单和权限',
				content:$("#addOrUpdateDiv"),
				area:['800px','600px'],
				success:function(index){
					url=api+"menu/addMenu";
					//重置表单
					$("#dataFrm")[0].reset();
					//加载最大的排序码
					$.get(api+"menu/queryMenuMaxSortCode",function(res){
						$("#sortCode").val(res.data);
					})
					$(".item_permission").hide();
					$(".item_topmenu").hide();
					$(".item_leftmenu").show();
				}
			});
		}
		function openUpdatemenu(data){
			mainIndex=layer.open({
				type:1,
				title:'修改['+data.title+']菜单和权限',
				content:$("#addOrUpdateDiv"),
				area:['800px','600px'],
				success:function(index){
					url=api+"menu/updateMenu";
					//装载数据表格
					form.val("dataFrm",data);
					$.get(api+"menu/getMenuById",{id:data.pid},function(res){
						console.log(res);
						if(res.data != null){
							$("#p_name").val(res.data.title);
						}
					});
					if(data.type=='topmenu'){
						$(".item_leftmenu").hide();
						$(".item_permission").hide();
						$(".item_topmenu").show();
					}else if(data.type=='leftmenu'){
						$(".item_permission").hide();
						$(".item_topmenu").hide();
						$(".item_leftmenu").show();
					}else{
						$(".item_leftmenu").hide();
						$(".item_topmenu").hide();
						$(".item_permission").show();
					}
				}
			});
		}
		//提交数据
		form.on("submit(doSubmit)",function(data){
			var params= $("#dataFrm").serialize();
			$.post(url,params, function(res){
				layer.msg(res.msg);
				if(res.code==200){
					tableIns.reload();
				}
				layer.close(mainIndex);
			})
			return false;
		})


		//监听菜单和权限选择的按钮事件打开菜单和权限选择的弹出层
		$("#doSelectMenu").click(function(){
			var p_id=$("#p_id").val();
			openMenuSelecter(p_id,function(id,name){
				$("#p_id").val(id);
				$("#p_name").val(name);
			});
		});
	});
</script>
<script>

</script>

</body>
</html>